package com.zlk.algorithm.huawei.leetcode.stack;

import java.util.Stack;

/**
 * @program: algorithm
 * @ClassName Code38_minStack
 * @description:MinStack
 *设计一个支持 push ，pop ，top 操作，并能在常数时间内检索到最小元素的栈。
 * 实现 MinStack 类:
 * MinStack() 初始化堆栈对象。
 * void push(int val) 将元素val推入堆栈。
 * void pop() 删除堆栈顶部的元素。
 * int top() 获取堆栈顶部的元素。
 * int getMin() 获取堆栈中的最小元素。
 *
 * @author: slfang
 * @create: 2025-01-13 14:24
 * @Version 1.0
 **/
public class MinStack {

//    示例 1:
//
//    输入：
//            ["MinStack","push","push","push","getMin","pop","top","getMin"]
//            [[],[-2],[0],[-3],[],[],[],[]]
//
//    输出：
//            [null,null,null,null,-3,null,0,-2]
//
//    解释：
//    MinStack minStack = new MinStack();
//    minStack.push(-2);
//    minStack.push(0);
//    minStack.push(-3);
//    minStack.getMin();   --> 返回 -3.
//    minStack.pop();
//    minStack.top();      --> 返回 0.
//    minStack.getMin();   --> 返回 -2.

    Stack<Integer> dataStack ;
    Stack<Integer> minStack ;
    public MinStack() {
        dataStack = new Stack<>();
        minStack = new Stack<>();
    }

    public void push(int val) {
        if (minStack.isEmpty() || val <= this.getMin()) {
            minStack.push(val);
        }
        dataStack.push(val);
    }

    public void pop() {
        Integer pop = dataStack.pop();
        if(pop==this.getMin()){
            minStack.pop();
        }
    }

    public int top() {
        return dataStack.peek();
    }

    public int getMin() {
        return minStack.peek();
    }
}
